.TH std::deque::prepend_range 3 "2024.06.10" "http://cppreference.com" "C++ Standard Libary"
.SH NAME
std::deque::prepend_range \- std::deque::prepend_range

.SH Synopsis
   template< container-compatible-range<T> R >  (since C++23)
   void prepend_range( R&& rg );

   Inserts, in non-reversing order, copies of elements in rg before begin(). Each
   iterator in the range rg is dereferenced exactly once.

   All iterators (including the end() iterator) are invalidated. No references are
   invalidated.

.SH Parameters

   rg             -             a container compatible range, that is, an input_range
                                whose elements are convertible to T
.SH Type requirements
   -
   T must be EmplaceConstructible into deque from *ranges::begin(rg). Also, T must be
   MoveInsertable into deque and T satisfies MoveConstructible, MoveAssignable, and
   Swappable. Otherwise, the behavior is undefined.

.SH Return value

   \fI(none)\fP

.SH Complexity

   Linear in size of rg.

.SH Notes

       Feature-test macro       Value    Std                   Feature
   __cpp_lib_containers_ranges 202202L (C++23) Ranges-aware construction and insertion

.SH Example


// Run this code

 #include <algorithm>
 #include <cassert>
 #include <deque>
 #include <vector>

 int main()
 {
     auto container = std::deque{0, 1, 2, 3};
     const auto rg = std::vector{-3, -2, -1};

 #if __cpp_lib_containers_ranges
     container.prepend_range(rg);
 #else
     container.insert(container.begin(), rg.cbegin(), rg.cend());
 #endif
     assert(std::ranges::equal(container, std::deque{-3, -2, -1, 0, 1, 2, 3}));
 }

.SH See also

   append_range  adds a range of elements to the end
   (C++23)       \fI(public member function)\fP
   insert_range  inserts a range of elements
   (C++23)       \fI(public member function)\fP
   push_front    inserts an element to the beginning
                 \fI(public member function)\fP
   emplace_front constructs an element in-place at the beginning
   \fI(C++11)\fP       \fI(public member function)\fP
